home *** CD-ROM | disk | FTP | other *** search
/ Aminet 6 / Aminet 6 - June 1995.iso / Aminet / util / cdity / RunList2.lha / RunList2 / Source / RListB.c < prev    next >
Encoding:
C/C++ Source or Header  |  1995-01-18  |  18.1 KB  |  636 lines

  1. /*
  2.  *  Source machine generated by GadToolsBox V2.0b
  3.  *  which is (c) Copyright 1991-1993 Jaba Development
  4.  *
  5.  *  GUI Designed by : -- Heinz Reinert --
  6.  */
  7. #include <exec/types.h>
  8. #include <intuition/intuition.h>
  9. #include <intuition/classes.h>
  10. #include <intuition/classusr.h>
  11. #include <intuition/imageclass.h>
  12. #include <intuition/gadgetclass.h>
  13. #include <libraries/gadtools.h>
  14. #include <graphics/displayinfo.h>
  15. #include <graphics/GfxBase.h>
  16. #include <clib/exec_protos.h>
  17. #include <clib/intuition_protos.h>
  18. #include <clib/gadtools_protos.h>
  19. #include <clib/graphics_protos.h>
  20. #include <clib/utility_protos.h>
  21. #include <proto/intuition.h>
  22. #include <proto/graphics.h>
  23. #include <proto/exec.h>
  24. #include <proto/dos.h>
  25. #include <proto/gadtools.h>
  26. #include <exec/memory.h>
  27. #include <string.h>
  28.  
  29. /*********************************************/
  30. #define GetString( g )      ((( struct StringInfo * )g->SpecialInfo )->Buffer  )
  31. #define GetNumber( g )      ((( struct StringInfo * )g->SpecialInfo )->LongInt )
  32.  
  33. #define GD_list                                0
  34. #define GD_gadtxt                              1
  35. #define GD_command                             2
  36. #define GD_command2                            3
  37. #define GD_new                                 4
  38. #define GD_del                                 5
  39. #define GD_start                               6
  40. #define GD_save                                7
  41. #define GD_Gadget80                            8
  42. #define GD_Gadget90                            9
  43.  
  44. #define GDX_list                               0
  45. #define GDX_gadtxt                             1
  46. #define GDX_command                            2
  47. #define GDX_command2                           3
  48. #define GDX_new                                4
  49. #define GDX_del                                5
  50. #define GDX_start                              6
  51. #define GDX_save                               7
  52. #define GDX_Gadget80                           8
  53. #define GDX_Gadget90                           9
  54.  
  55. #define Project0_CNT 10
  56. UBYTE *vers = "\0$VER: RunList 2";
  57.  
  58. extern struct IntuitionBase *IntuitionBase;
  59. extern struct Library       *GadToolsBase;
  60.  
  61. extern struct Screen        *Scr;
  62. extern UBYTE                 *PubScreenName;
  63. extern APTR                  VisualInfo;
  64. extern struct Window        *Project0Wnd;
  65. extern struct Gadget        *Project0GList;
  66. extern struct Gadget        *Project0Gadgets[10];
  67. extern UWORD                 Project0Left;
  68. extern UWORD                 Project0Top;
  69. extern UWORD                 Project0Width;
  70. extern UWORD                 Project0Height;
  71. extern UBYTE                *Project0Wdt;
  72. extern struct TextAttr       topaz8;
  73. extern UWORD                 Project0GTypes[];
  74. extern struct NewGadget      Project0NGad[];
  75. extern ULONG                 Project0GTags[];
  76.  
  77.  
  78. extern int SetupScreen( void );
  79. extern void CloseDownScreen( void );
  80. extern int OpenProject0Window( void );
  81. extern void CloseProject0Window( void );
  82.  
  83. /*********************************************/
  84.  
  85. struct Screen         *Scr = NULL;
  86. UBYTE                 *PubScreenName = NULL;
  87. APTR                   VisualInfo = NULL;
  88. struct Window         *Project0Wnd = NULL;
  89. struct Gadget         *Project0GList = NULL;
  90. struct Gadget         *Project0Gadgets[10];
  91. UWORD                  Project0Left = 347;
  92. UWORD                  Project0Top = 10;
  93. UWORD                  Project0Width = 305;
  94. UWORD                  Project0Height = 0;
  95. UBYTE                 *Project0Wdt = (UBYTE *)"RunList B2";
  96.  
  97. struct TextAttr topaz8 = {
  98.         ( STRPTR )"topaz.font", 8, 0x00, 0x01 };
  99.  
  100. UWORD Project0GTypes[] = {
  101.         LISTVIEW_KIND,
  102.         STRING_KIND,
  103.         STRING_KIND,
  104.         STRING_KIND,
  105.         BUTTON_KIND,
  106.         BUTTON_KIND,
  107.         BUTTON_KIND,
  108.         BUTTON_KIND,
  109.         TEXT_KIND,
  110.         TEXT_KIND
  111. };
  112.  
  113. struct NewGadget Project0NGad[] = {
  114.         21, 9, 162, 152, NULL, NULL, GD_list, 0, NULL, NULL,
  115.         21, 159, 162, 12, NULL, NULL, GD_gadtxt, 0, NULL, NULL,
  116.         6, 183, 272, 12, NULL, NULL, GD_command, 0, NULL, NULL,
  117.         6, 195, 272, 12, NULL, NULL, GD_command2, 0, NULL, NULL,
  118.         186, 9, 77, 18, (UBYTE *)"NEW", NULL, GD_new, PLACETEXT_IN, NULL, NULL,
  119.         186, 28, 77, 18, (UBYTE *)"DELETE", NULL, GD_del, PLACETEXT_IN, NULL, NULL,
  120.         186, 66, 76, 105, (UBYTE *)"RUN", NULL, GD_start, PLACETEXT_IN, NULL, NULL,
  121.         186, 47, 77, 18, (UBYTE *)"SAVE", NULL, GD_save, PLACETEXT_IN, NULL, NULL,
  122.         14, 6, 255, 169, NULL, NULL, GD_Gadget80, 0, NULL, NULL,
  123.         7, 3, 269, 177, NULL, NULL, GD_Gadget90, 0, NULL, NULL
  124. };
  125.  
  126. ULONG Project0GTags[] = {
  127.         (TAG_DONE),
  128.         (GTST_MaxChars), 20, (TAG_DONE),
  129.         (GTST_MaxChars), 50, (TAG_DONE),
  130.         (GTST_MaxChars), 50, (TAG_DONE),
  131.         (TAG_DONE),
  132.         (TAG_DONE),
  133.         (TAG_DONE),
  134.         (TAG_DONE),
  135.         (GTTX_Border), TRUE, (TAG_DONE),
  136.         (GTTX_Border), TRUE, (TAG_DONE)
  137. };
  138.  
  139. int SetupScreen( void )
  140. {
  141.         if ( ! ( Scr = LockPubScreen( PubScreenName )))
  142.                 return( 1L );
  143.  
  144.         if ( ! ( VisualInfo = GetVisualInfo( Scr, TAG_DONE )))
  145.                 return( 2L );
  146.  
  147.         return( 0L );
  148. }
  149.  
  150. void CloseDownScreen( void )
  151. {
  152.         if ( VisualInfo ) {
  153.                 FreeVisualInfo( VisualInfo );
  154.                 VisualInfo = NULL;
  155.         }
  156.  
  157.         if ( Scr        ) {
  158.                 UnlockPubScreen( NULL, Scr );
  159.                 Scr = NULL;
  160.         }
  161. }
  162.  
  163. int OpenProject0Window( void )
  164. {
  165.         struct NewGadget        ng;
  166.         struct Gadget   *g;
  167.         UWORD           lc, tc;
  168.         UWORD           offx = Scr->WBorLeft, offy = Scr->WBorTop + Scr->RastPort.TxHeight + 1;
  169.  
  170.         if ( ! ( g = CreateContext( &Project0GList )))
  171.                 return( 1L );
  172.  
  173.         for( lc = 0, tc = 0; lc < Project0_CNT; lc++ ) {
  174.  
  175.                 CopyMem((char * )&Project0NGad[ lc ], (char * )&ng, (long)sizeof( struct NewGadget ));
  176.  
  177.                 ng.ng_VisualInfo = VisualInfo;
  178.                 ng.ng_TextAttr   = &topaz8;
  179.                 ng.ng_LeftEdge  += offx;
  180.                 ng.ng_TopEdge   += offy;
  181.  
  182.                 Project0Gadgets[ lc ] = g = CreateGadgetA((ULONG)Project0GTypes[ lc ], g, &ng, ( struct TagItem * )&Project0GTags[ tc ] );
  183.  
  184.                 while( Project0GTags[ tc ] ) tc += 2;
  185.                 tc++;
  186.  
  187.                 if ( NOT g )
  188.                         return( 2L );
  189.         }
  190.  
  191.         if ( ! ( Project0Wnd = OpenWindowTags( NULL,
  192.                                 WA_Left,        Project0Left,
  193.                                 WA_Top,         Project0Top,
  194.                                 WA_Width,       Project0Width,
  195.                                 WA_Height,      Project0Height + offy,
  196.                                 WA_IDCMP,       LISTVIEWIDCMP|
  197.                                                 BUTTONIDCMP|
  198.                                                 STRINGIDCMP|
  199.                                                 IDCMP_NEWSIZE|
  200.                                                 IDCMP_MENUPICK|
  201.                                                 IDCMP_CLOSEWINDOW|
  202.                                                 IDCMP_CHANGEWINDOW|
  203.                                                 IDCMP_INTUITICKS |
  204.                                                 IDCMP_MOUSEBUTTONS|
  205.                                                 IDCMP_REFRESHWINDOW,
  206.                                 WA_Flags,       WFLG_SIZEGADGET|
  207.                                                 WFLG_DRAGBAR|
  208.                                                 WFLG_DEPTHGADGET|
  209.                                                 WFLG_CLOSEGADGET|
  210.                                                 WFLG_SMART_REFRESH,
  211.                                 WA_Gadgets,     Project0GList,
  212.                                 WA_Title,       Project0Wdt,
  213.                                 WA_ScreenTitle, "RunListB2 Heinz Reinert 1994-95",
  214.                                 WA_PubScreen,   Scr,
  215.                                 WA_MinWidth,    305,
  216.                                 WA_MinHeight,   222,
  217.                                 WA_MaxWidth,    305,
  218.                                 WA_MaxHeight,   222,
  219.                                 TAG_DONE )))
  220.         return( 4L );
  221.  
  222.         GT_RefreshWindow( Project0Wnd, NULL );
  223.  
  224.         return( 0L );
  225. }
  226.  
  227. void CloseProject0Window( void )
  228. {
  229.         if ( Project0Wnd        ) {
  230.                 CloseWindow( Project0Wnd );
  231.                 Project0Wnd = NULL;
  232.         }
  233.  
  234.         if ( Project0GList      ) {
  235.                 FreeGadgets( Project0GList );
  236.                 Project0GList = NULL;
  237.         }
  238. }
  239. /***************************************/
  240.  
  241. /* Main Program Part */
  242.  
  243. /* Structur for Data-Entries */
  244.  
  245. struct PRJ {
  246.  
  247.     char    Name[5];
  248.  
  249.     char    gadtxt[20];
  250.     char    command[50];
  251.     char    command2[50];
  252.     USHORT  new;
  253.     USHORT  del;
  254.     USHORT  save;
  255.     USHORT  req;
  256.     USHORT  start;
  257. };
  258.  
  259. struct PRJnode {
  260.         struct  Node n;
  261.         struct  PRJ d;
  262. };
  263.  
  264. /* PRJ-Nodes are in this List */
  265.  
  266. struct List prjlist;
  267.  
  268. /* The actual Entry */
  269.  
  270. struct PRJnode *currentprj;
  271.  
  272. /* String-Gadgets */
  273.  
  274. void gt_SetString( struct Gadget        *gad,
  275.                                    struct Window        *w,
  276.                                    char                         *string )
  277. {
  278.         GT_SetGadgetAttrs( gad, w, NULL, GTST_String, string, TAG_DONE );
  279. }
  280.  
  281. char * gt_GetString( struct Gadget      *gad )
  282. {
  283.         struct StringInfo *si = gad->SpecialInfo;
  284.  
  285.         if( si )
  286.                 return( ( char * ) si->Buffer );
  287.         else
  288.                 return( NULL );
  289. }
  290.  
  291. /* Manage Lists for Listview-Gadgets */
  292. /* Add List */
  293.  
  294. void gt_AttachList(     struct Gadget   *lv,
  295.                                         struct Window   *w,
  296.                                         struct List     *list )
  297. {
  298.         GT_SetGadgetAttrs( lv, w, NULL, GTLV_Labels, list, TAG_DONE );
  299. }
  300.  
  301. /* Put Actuel Entry */
  302.  
  303. void gt_SetLV( struct Gadget    *gad,
  304.                            struct Window        *w,
  305.                            ULONG                        value)
  306. {
  307.         GT_SetGadgetAttrs( gad, w, NULL, GTLV_Selected, value, TAG_DONE );
  308. }
  309.  
  310. /* get x-Entry from Exec-List */
  311.  
  312. struct Node * gt_GetListEntry( struct List *l,
  313.                                                            int num )
  314. {
  315.         int count = 0;
  316.         struct Node *n = l->lh_Head;
  317.  
  318.         while( n->ln_Succ )
  319.         {
  320.                 if( num==count ) return( n );
  321.                 n = n->ln_Succ;
  322.                 count++;
  323.         }
  324.         return( NULL );
  325. }
  326.  
  327. /* Number of a Node in List? */
  328.  
  329. int gt_GetListEntryNum( struct List *l,
  330.                                                 struct Node *n )
  331. {
  332.         int count = 0;
  333.         struct Node *r = l->lh_Head;
  334.  
  335.         while( r->ln_Succ )
  336.         {
  337.                 if( r==n ) return( count );
  338.                 r = r->ln_Succ;
  339.                 count++;
  340.         }
  341.         return( -1 );
  342. }
  343.  
  344. /* Count Entries of List */
  345.  
  346. int gt_GetListNumEntries( struct List *l )
  347. {
  348.         int count = 0;
  349.         struct Node *n = l->lh_Head;
  350.  
  351.         while( n->ln_Succ )
  352.         {
  353.                 n = n->ln_Succ;
  354.                 count++;
  355.         }
  356.  
  357.         return( count );
  358. }
  359.  
  360. /************************************************************************/
  361.  
  362. /* Load Command.DAT */
  363.  
  364. void loadprjlist( void )
  365. {
  366.         struct PRJ new;
  367.         struct PRJnode *n;
  368.         BPTR f;
  369.  
  370.         /* Init List */
  371.         NewList( &prjlist );
  372.         currentprj = NULL;
  373.  
  374.         /* Open Com.DAT */
  375.         f = Open( "S:Command.LIST", MODE_OLDFILE );
  376.         if( !f )
  377.                 return;
  378.  
  379.         /* Inputs read in */
  380.         while( Read( f, &new, sizeof( new ) ) == sizeof( new ) )
  381.         {
  382.                /* New Node */
  383.                 n = AllocVec( sizeof( *n ), 0 );
  384.                 if( !n )
  385.                         break;
  386.  
  387.         /* Copy Structur and add to List */
  388.                 n->d = new;
  389.                 n->n.ln_Name = n->d.Name;
  390.                 n->n.ln_Pri      = - n->d.Name[0];
  391.                 Enqueue( &prjlist, (struct Node *) n );
  392.         }
  393.  
  394.         Close( f );
  395. }
  396.  
  397. /* Saves List and Frees it */
  398. void save_and_freeprjlist( void )
  399. {
  400.         struct PRJnode *n;
  401.         BPTR f;
  402.  
  403.         f = Open( "S:Command.LIST", MODE_NEWFILE );
  404.  
  405.         while( ( n = (struct PRJnode * ) RemHead( &prjlist ) ) )
  406.         {
  407.             /* Save Node */
  408.                 if( f )
  409.                         Write( f, &n->d, sizeof( struct PRJ ) );
  410.             /* Free Node */
  411.                 FreeVec( n );
  412.         }
  413.  
  414.         if( f )
  415.                 Close( f );
  416. }
  417.  
  418.  
  419. /************************************************************************/
  420.  
  421. /* Puts actual Structur-Values to Gadgets */
  422.  
  423. void setgadvals( void )
  424. {
  425.  
  426.         if( !currentprj )
  427.             return;
  428.  
  429.         gt_SetString(   Project0Gadgets[ GD_gadtxt ], Project0Wnd,
  430.                                                        currentprj->d.Name );
  431.  
  432.         gt_SetString(   Project0Gadgets[ GD_command ], Project0Wnd,
  433.                                                     currentprj->d.command );
  434.  
  435.         gt_SetString(   Project0Gadgets[ GD_command2 ], Project0Wnd,
  436.                                                     currentprj->d.command2 );
  437.  
  438. }
  439.  
  440. /* Create a new Empty Input */
  441.  
  442. void newprj( void )
  443. {
  444.         struct PRJnode *new;
  445.  
  446.         new = AllocVec( sizeof( *new ), MEMF_CLEAR );
  447.  
  448.         if( !new )
  449.                 return;
  450.  
  451.         currentprj = new;
  452.  
  453.         new->n.ln_Name = new->d.Name;
  454.  
  455.         strcpy( new->d.Name, "new" );
  456.  
  457.         gt_AttachList( Project0Gadgets[GD_list], Project0Wnd,
  458.                                                       (struct List *) ~0 );
  459.  
  460.         new->n.ln_Pri    = - new->d.Name[0];
  461.         Enqueue( &prjlist, (struct Node *) new );
  462.  
  463.         gt_AttachList( Project0Gadgets[GD_list], Project0Wnd, &prjlist );
  464.  
  465.         gt_SetLV( Project0Gadgets[GD_list], Project0Wnd,
  466.                                      gt_GetListEntryNum( &prjlist, new ) );
  467.         setgadvals();
  468. }
  469.  
  470. /* Work on Gadget-Event */
  471. void dogadup( struct IntuiMessage *im )
  472. {
  473.         struct Gadget *g = im->IAddress;
  474.  
  475.         switch( g->GadgetID )
  476.         {
  477.  
  478. /*** Enter List ***/
  479. case GD_list:
  480.         currentprj = (struct PRJnode *) gt_GetListEntry( &prjlist, im->Code );
  481.         setgadvals();
  482.         break;
  483.  
  484. /*** New ***/
  485. case GD_new:
  486.         newprj();
  487.         break;
  488.  
  489. /*** Delete ***/
  490. case GD_del:
  491.         if( currentprj )
  492.         {
  493.         gt_AttachList( Project0Gadgets[ GD_list ], Project0Wnd,
  494.                                                        (struct List *) ~0 );
  495.         Remove( currentprj );
  496.         FreeVec( currentprj );
  497.         currentprj = FALSE;
  498.         gt_AttachList( Project0Gadgets[ GD_list ], Project0Wnd, &prjlist );
  499.         gt_SetLV( Project0Gadgets[ GD_list ], Project0Wnd, ~0 );
  500.         }
  501.         break;
  502. /*** Program Name ***/
  503. case GD_gadtxt:
  504.         if( currentprj )
  505.         {
  506.         gt_AttachList( Project0Gadgets[ GD_list ], Project0Wnd,
  507.                                                          (struct List *) ~0 );
  508.    strcpy( currentprj->d.Name, gt_GetString( Project0Gadgets[ GD_gadtxt ] ) );
  509.         gt_AttachList( Project0Gadgets[ GD_list ], Project0Wnd, &prjlist );
  510.         }
  511.         break;
  512.  
  513. /*** Command-string ***/
  514. case GD_command:
  515.         if( currentprj )
  516.         strcpy( currentprj->d.command,
  517.                              gt_GetString( Project0Gadgets[ GD_command ] ) );
  518.         break;
  519.  
  520. /*** Command-string ***/
  521. case GD_command2:
  522.         if( currentprj )
  523.         strcpy( currentprj->d.command2,
  524.                              gt_GetString( Project0Gadgets[ GD_command2 ] ) );
  525.         break;
  526.  
  527. /*** Start Program ***/
  528. case GD_start:
  529.         Execute(currentprj->d.command, NULL, Output());
  530.         Execute("Wait 2 secs", NULL, Output());
  531.         Execute(currentprj->d.command2, NULL, Output());
  532.         break;
  533.  
  534. /*** Save List ***/
  535. case GD_save:
  536.         {
  537.             save_and_freeprjlist();
  538.             loadprjlist();
  539.         }
  540.         break;
  541.         }
  542. }
  543.  
  544. /* Program start */
  545.  
  546. int main( void )
  547. {
  548.  
  549.         struct IntuiMessage     *im,imsg;
  550.         BOOL   Done = FALSE;
  551.  
  552.         /* Store some data copied from the IntuitionMessage in these variables: */
  553.         USHORT code;           /* Code. */
  554.         ULONG seconds, micros; /* Time. */
  555.  
  556.  
  557.         /* Declare and initialize the time stamps: */
  558.         ULONG sec1 = 0;
  559.         ULONG mic1 = 0;
  560.         ULONG sec2 = 0;
  561.         ULONG mic2 = 0;
  562.  
  563.         SetupScreen();
  564.         OpenProject0Window();
  565.  
  566.         loadprjlist();
  567.  
  568.         gt_AttachList( Project0Gadgets[GD_list], Project0Wnd, &prjlist );
  569.  
  570.         while( !Done )
  571.         {
  572.  
  573.                 while( !( im=GT_GetIMsg( Project0Wnd->UserPort ) ) )
  574.                         WaitPort( Project0Wnd->UserPort );
  575.  
  576.                     code    = im->Code;
  577.                     seconds = im->Seconds;
  578.                     micros  = im->Micros;
  579.  
  580.                 imsg = *im;
  581.                 GT_ReplyIMsg( im );
  582.  
  583.                 switch( imsg.Class )
  584.                 {
  585.  
  586.                         case IDCMP_CLOSEWINDOW:
  587.                                 Done = TRUE;
  588.                                 break;
  589.  
  590.                         case IDCMP_GADGETUP:
  591.                                 dogadup( &imsg );
  592.                                 break;
  593.  
  594.                         case IDCMP_MOUSEBUTTONS: /* The user pressed/released a mouse button. */
  595.                                 if( code == SELECTDOWN )
  596.                                 {
  597.                                    /* Left button pressed. */
  598.  
  599.                                    /* Save the old time: */
  600.                                     sec2 = sec1;
  601.                                     mic2 = mic1;
  602.  
  603.                                    /* Get the new time: */
  604.                                     sec1 = seconds;
  605.                                     mic1 = micros;
  606.  
  607.                                    /* Check if it was a double-click or not: */
  608.                                 if( DoubleClick( sec2, mic2, sec1, mic1 ) )
  609.                                 {
  610.                                     Execute("RUN >NIL: Shellwin ", NULL, Output());
  611.                                    /* Reset the values: */
  612.                                     sec1 = 0;
  613.                                     mic1 = 0;
  614.                                     }
  615.                                 }
  616.                                 break;
  617.  
  618.  
  619.                         case IDCMP_REFRESHWINDOW:
  620.                                 GT_BeginRefresh( Project0Wnd );
  621.                                 GT_EndRefresh( Project0Wnd, TRUE );
  622.                                 break;
  623.  
  624.                 }
  625.  
  626.         }
  627.  
  628.         CloseProject0Window();
  629.         CloseDownScreen();
  630.  
  631.         return(0);
  632. }
  633.  
  634.  
  635.  
  636.